<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>layui</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <link rel="stylesheet" href="./lib/layui-v2.6.3/css/layui.css" media="all">
    <link rel="stylesheet" href="./css/public.css" media="all">
</head>
<body>
<div class="layuimini-container">
    <div class="layuimini-main">

        <fieldset class="table-search-fieldset">
            <legend>搜索信息</legend>
            <div style="margin: 10px 10px 10px 10px">
                <form class="layui-form layui-form-pane" action="">
                    <div class="layui-form-item">
                        <div class="layui-inline">
                            <label class="layui-form-label">计划类型</label>
                            <div class="layui-input-inline">
                                <select name="type" lay-filter="type">
                                    <option value="">请选择</option>
                                    <option value="配变电">配变电</option>
                                    <option value="线路">线路</option>
                                </select>
                            </div>
                        </div>
                        <div class="layui-inline">
                            <label class="layui-form-label">资产编号</label>
                            <div class="layui-input-inline">
                                <input type="text" name="propertyNumber" autocomplete="off" class="layui-input">
                            </div>
                        </div>
                        <div class="layui-inline">
                            <label class="layui-form-label">项目编号</label>
                            <div class="layui-input-inline">
                                <input type="text" name="projectNumber" autocomplete="off" class="layui-input">
                            </div>
                        </div>
                        <div class="layui-inline">
                            <label class="layui-form-label">项目名称</label>
                            <div class="layui-input-inline">
                                <input type="text" name="projectName" autocomplete="off" class="layui-input">
                            </div>
                        </div>
                        <div class="layui-inline">
                            <label class="layui-form-label">状态</label>
                            <div class="layui-input-inline">
                                <select name="status" lay-filter="status">
                                    <option value="">请选择</option>
                                    <option value="0">未完成</option>
                                    <option value="1">已完成</option>
                                </select>
                            </div>
                        </div>
                        <div class="layui-inline">
                            <button type="submit" class="layui-btn layui-btn-primary" lay-submit lay-filter="data-search-btn">
                                <i class="layui-icon"></i> 搜 索
                            </button>
                        </div>
                    </div>
                </form>

            </div>
        </fieldset>

        <script type="text/html" id="toolbarDemo">
            <div class="layui-btn-container">
                <button class="layui-btn layui-btn-normal layui-btn-sm data-add-btn" lay-event="add"> 添加 </button>
                <button class="layui-btn layui-btn-sm layui-btn-danger data-delete-btn" lay-event="delete"> 删除 </button>
                <!-- 在搜索栏或工具栏中添加导入按钮 -->
                <button class="layui-btn layui-btn-sm" id="importBtn">Excel导入</button>
                <input type="file" id="excelFile" style="display: none;" accept=".xls, .xlsx" />
            </div>
        </script>

        <table class="layui-hide" id="currentTableId" lay-filter="currentTableFilter"></table>

        <script type="text/html" id="currentTableBar">
            <a class="layui-btn layui-btn-normal layui-btn-xs data-count-edit" lay-event="edit">编辑</a>
            <a class="layui-btn layui-btn-xs layui-btn-danger data-count-delete" lay-event="delete">删除</a>
        </script>

    </div>
</div>
<script src="./lib/layui-v2.6.3/layui.js" charset="utf-8"></script>
<script>
    layui.use(['form', 'table'], function () {
        var $ = layui.jquery,
            form = layui.form,
            table = layui.table;
        table.render({
            elem: '#currentTableId',
            url: 'plan/normal/list',
            method:'post',
            parseData: function (res) {
                // res 即为后端返回的数据
                return {
                    "code": res.code === 0 ? 0 : 1,   // 0 表示成功
                    "msg": res.msg,
                    "count": res.data.total,          // 总数
                    "data": res.data.list             // 数据列表
                };
            },
            toolbar: '#toolbarDemo',
            defaultToolbar: ['filter', 'exports', 'print', {
                title: '提示',
                layEvent: 'LAYTABLE_TIPS',
                icon: 'layui-icon-tips'
            }],
            cols: [[
                {type: "checkbox", width: 50},
                {field: 'id', width: 80, title: 'ID', sort: true},
                {field: 'type', width: 100, title: '计划类型'},
                {field: 'propertyNumber', width: 120, title: '资产编号'},
                {field: 'projectNumber', width: 120, title: '项目编号'},
                {field: 'projectName', width: 120, title: '项目名称'},
                {field: 'materialsDescription', width: 150, title: '废旧物料描述'},
                {field: 'finishTime', width: 150, title: '计划完成时间', templet: function(d) {
                        return new Date(d.finishTime).toLocaleDateString();
                    }},
                {field: 'quantity', width: 100, title: '数量'},
                {field: 'status', width: 100, title: '状态', templet: function(d) {
                        return d.status === 0 ? '未完成' : '已完成';
                    }},
                {title: '操作', minWidth: 150, toolbar: '#currentTableBar', align: "center"}
            ]],
            limits: [10, 15, 20, 25, 50, 100],
            limit: 15,
            page: true,
            skin: 'line'
        });

        // 监听导入按钮点击事件
        $('#importBtn').on('click', function () {
            $('#excelFile').click(); // 触发隐藏的文件选择框
        });

        // 文件选择变化时上传
        $('#excelFile').on('change', function () {
            var file = this.files[0];
            if (!file) return;

            var formData = new FormData();
            formData.append("file", file);

            layer.load(2); // 显示加载动画

            $.ajax({
                url: '/plan/normal/batch/add',
                type: 'POST',
                data: formData,
                contentType: false,
                processData: false,
                success: function (res) {
                    layer.closeAll('loading');
                    if (res.code === 0) {
                        layer.msg('导入成功');
                        table.reload('currentTableId'); // 刷新表格
                    } else {
                        layer.msg('导入失败：' + res.msg);
                    }
                },
                error: function () {
                    layer.closeAll('loading');
                    layer.msg('网络异常，请稍后再试');
                }
            });
        });

        // 监听搜索操作
        form.on('submit(data-search-btn)', function (data) {
            // 重新渲染下拉框样式
            form.render('select');

            // 执行搜索重载
            table.reload('currentTableId', {
                page: { curr: 1 },
                where: {
                    page: 1,
                    limit: 15,
                    type: data.field.type,
                    propertyNumber: data.field.propertyNumber,
                    projectNumber: data.field.projectNumber,
                    projectName: data.field.projectName,
                    status: data.field.status
                }
            }, 'data');

            return false;
        });


        /**
         * toolbar监听事件
         */
        table.on('toolbar(currentTableFilter)', function (obj) {
            if (obj.event === 'add') {  // 监听添加操作
                var index = layer.open({
                    title: '添加用户',
                    type: 2,
                    shade: 0.2,
                    maxmin:true,
                    shadeClose: true,
                    area: ['100%', '100%'],
                    content: 'plan-normal-add.html',
                });
                $(window).on("resize", function () {
                    layer.full(index);
                });
            } else if (obj.event === 'delete') {  // 监听删除操作
                var checkStatus = table.checkStatus('currentTableId')
                    , data = checkStatus.data;
                if (data.length === 0) {
                    layer.msg('请选择要删除的数据');
                    return;
                }
                const ids = data.map(item => item.id);

                layer.confirm('确定删除选中的 ' + data.length + ' 条记录？', function (index) {
                    const loadingIndex = layer.load(2); // 加载动画

                    $.ajax({
                        url: '/plan/normal/delete',
                        type: 'DELETE',
                        contentType: 'application/json',
                        data: JSON.stringify(ids),
                        success: function (res) {
                            layer.close(loadingIndex);
                            if (res.code === 0) {
                                layer.msg('删除成功');
                                table.reload('currentTableId'); // 刷新表格
                            } else {
                                layer.msg('删除失败：' + res.msg);
                            }
                        },
                        error: function () {
                            layer.close(loadingIndex);
                            layer.msg('网络异常，请稍后再试');
                        }
                    });

                    layer.close(index);
                });
            }
        });

        //监听表格复选框选择
        table.on('checkbox(currentTableFilter)', function (obj) {
            console.log(obj)
        });

        table.on('tool(currentTableFilter)', function (obj) {
            var data = obj.data;
            if (obj.event === 'edit') {

                var index = layer.open({
                    title: '编辑计划',
                    type: 2,
                    shade: 0.2,
                    maxmin:true,
                    shadeClose: true,
                    area: ['100%', '100%'],
                    content: 'plan-normal-edit.html',
                    success: function(layero, index){
                        // 数据传递到子页面
                        var iframe = layero.find('iframe')[0].contentWindow;
                        iframe.loadData && iframe.loadData(data);
                    }
                });
                $(window).on("resize", function () {
                    layer.full(index);
                });
                return false;
            } else if (obj.event === 'delete') {  // 监听删除操作
                layer.confirm('真的删除行么', function (index) {
                    //删除单条数据
                    $.ajax({
                        url: '/plan/normal/delete/'+data.id,
                        type: 'DELETE',
                        success: function (res) {
                            if (res.code === 0) {
                                layer.msg('删除成功');
                                table.reload('currentTableId'); // 刷新表格
                            }
                            else {
                                layer.msg('删除失败：' + res.msg);
                            }
                        }
                    })
                    layer.close(index);
                });
            }

        });

    });
</script>

</body>
</html>